草庐IT

c++ - std::equal_range 与 lambda

全部标签

c++ - 在 C++11 线程中,std::mutex 对内存可见性有什么保证?

我目前正在尝试学习C++11线程API,但我发现各种资源都没有提供重要的信息:CPU缓存的处理方式。现代CPU的每个核心都有一个缓存(意味着不同的线程可能使用不同的缓存)。这意味着一个线程有可能将一个值写入内存,而另一个线程可能看不到它,即使它看到第一个线程也进行了其他更改。当然,任何好的线程API都提供了一些方法来解决这个问题。然而,在C++的线程api中,它是如何工作的并不清楚。我知道std::mutex,例如,以某种方式保护内存,但不清楚它的作用:它是否清除整个CPU缓存,是否清除从当前线程的缓存中清除互斥体内部访问的对象,或者其他什么?此外,显然,只读访问不需要互斥量,但是如果

c++ - 模板类型推导失败(std::empty 作为谓词)

我有一个vector的vector,我想检查它们是否都是空的。使用标准库,我试过:#include#includeintmain(){std::vector>vv;std::all_of(std::begin(vv),std::end(vv),std::empty);}这会导致clang7.0出现以下错误:/usr/bin/../lib/gcc/x86_64-linux-gnu/6.3.0/../../../../include/c++/6.3.0/bits/stl_algo.h:508:5:note:candidatetemplateignored:couldn'tinfertemp

C++ lambda函数调用纯虚函数

我正在尝试为std::thread创建一个包装器类。此类提供了一个启动线程并调用纯虚函数的kick方法。我正在使用派生类来调用这个kick方法,派生类也实现了虚函数。classExecutor{public://constructorExecutor();//destructor~Executor();//kickthreadexecutionvoidKick();private://threadexecutionfunctionvirtualvoidStartExecution()=0;//threadhandlestd::threadmThreadHandle;};下面是执行器类的

c++/c 访问具有不同名称和大小的多个字符数组

我正在分析一个pcap文件,并在Wireshark中将剖析导出为c数组,我需要从相关字节中提取一些数据。但是我不知道如何访问所有这些数组。它们看起来像这样:/*Frame(73bytes)*/staticconstunsignedcharpkt1324[73]={0x80,0xe6,0x50,0x06,0xe7,0xae,0x48,0xfd,/*..P...H.*/0x8e,0xdf,0x2f,0x06,0x86,0xdd,0x60,0x00,/*../...`.*/0x00,0x00,0x00,0x13,0x11,0x30,0x20,0x01,/*.....0.*/0x06,0x60

c++ - 为什么这个悬空的 std::weak_ptr 不会导致 SEGFAULT?

这个问题在这里已经有了答案:Whendoesinvokingamemberfunctiononanullinstanceresultinundefinedbehavior?(2个答案)关闭4年前。在下面的代码中,我在范围内创建了一个shared_ptr并将其分配给一个weak_ptr。为什么在运行代码时我没有得到SEGFAULT,因为wp应该在范围之外无效,对吧?namespace{structDummy{intx;voidfoo(){std::coutwp;{autosp=std::make_shared();wp=sp;}wp.lock()->foo();};

c++ - 指向 std::invoke 中成员函数对象的指针

为什么std::invoke不能使用指向成员的指针,而成员是带参数的函数对象?像这样:structMyClass{std::functionfunctor{[](intarg){printf("%d\n",arg);}};};intmain(){MyClassmc;std::invoke(&MyClass::functor,mc,110);}打印:'std::invoke':nomatchingoverloadedfunctionfound.我在VisualC++和g++中检查了这一点。此外,std::is_invocable_v声称此仿函数不可调用,这绝对是错误的。我是否遗漏了什么或

c++ - 确保 std::bind 提供正确数量的参数

更改std::function的签名后,我想知道编译器没有提示我还没有更改的函数签名。基本上,我的代码如下所示:#include#include#includeclassCallbackCaller{public:typedefstd::functionCallbackFunction;voidregisterCallbackFunction(CallbackFunctioncb_function){callback_functions_.push_back(cb_function);}voidcallThemAll(){for(CallbackFunction&cb_function

c++ - std::bind 可变参数模板和自动返回类型

遵循thisquestion中的代码,我有一个带有可变参数模板函数的std::bind。如果我尝试提供带有auto返回值的函数模​​板,gcc会拒绝该程序:#includetemplateautoinv(Args...args){autobound=std::bind(&inv_impl,args...);returnbound;}intmain(){autob=inv(1,2);}编译错误为:foo.cc:Ininstantiationof‘autoinv(Args...)[withArgs={int,int}]’:foo.cc:41:30:requiredfromherefoo.c

c++ - 当工件是库且标志影响 C 或 C++ header 时,功能标志/切换

关于featureflags/toggles的讨论很多。和whyyouwouldusethem但大多数关于实现它们的讨论都围绕(网络或客户端)应用程序展开。如果您的产品/工件是C或C++库,并且您的公共(public)header受标志影响,您将如何实现它们?“天真”的做法并没有真正奏效:///Doessomething/***Doessomethingreallycool#ifdefFEATURE_FOO*@paramfooParamdescribeparamforfoo#endif*/voiddoSomethingCool(#ifdefFEATURE_FOOintfooParam=

c++ - 使用 std::greater

我很好奇std::greater的用途.与sort一起使用时,它按降序输出数字。但是当与priority_queue一起使用时,数字按升序输出。为什么会这样?例子:#include//std::cout#include//std::greater#include//std::sort#include//std::priority_queueintmain(){intnumbers[]={20,40,50,10,30};std::priority_queue,std::greater>pq(numbers,numbers+5);std::sort(numbers,numbers+5,st